home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c08 / newcollections / Map1.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  4.9 KB  |  130 lines

  1. //: Map1.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // Things you can do with Maps
  50. package c08.newcollections;
  51. import java.util.*;
  52.  
  53. public class Map1 {
  54.   public final static String[][] testData1 = {
  55.     { "Happy", "Cheerful disposition" },
  56.     { "Sleepy", "Prefers dark, quiet places" },
  57.     { "Grumpy", "Needs to work on attitude" },
  58.     { "Doc", "Fantasizes about advanced degree"},
  59.     { "Dopey", "'A' for effort" },
  60.     { "Sneezy", "Struggles with allergies" },
  61.     { "Bashful", "Needs self-esteem workshop"},
  62.   };
  63.   public final static String[][] testData2 = {
  64.     { "Belligerent", "Disruptive influence" },
  65.     { "Lazy", "Motivational problems" },
  66.     { "Comatose", "Excellent behavior" }
  67.   };
  68.   public static Map fill(Map m, Object[][] o) {
  69.     for(int i = 0; i < o.length; i++)
  70.       m.put(o[i][0], o[i][1]);
  71.     return m;
  72.   }
  73.   // Producing a Set of the keys:
  74.   public static void printKeys(Map m) {
  75.     System.out.print("Size = " + m.size() +", ");
  76.     System.out.print("Keys: ");
  77.     Collection1.print(m.keySet());
  78.   }
  79.   // Producing a Collection of the values:
  80.   public static void printValues(Map m) {
  81.     System.out.print("Values: ");
  82.     Collection1.print(m.values());
  83.   }
  84.   // Iterating through Map.Entry objects (pairs):
  85.   public static void print(Map m) {
  86.     Collection entries = m.entries();
  87.     Iterator it = entries.iterator();
  88.     while(it.hasNext()) {
  89.       Map.Entry e = (Map.Entry)it.next();
  90.       System.out.println("Key = " + e.getKey() +
  91.         ", Value = " + e.getValue());
  92.     }
  93.   }
  94.   public static void test(Map m) {
  95.     fill(m, testData1);
  96.     // Map has 'Set' behavior for keys:
  97.     fill(m, testData1);
  98.     printKeys(m);
  99.     printValues(m);
  100.     print(m);
  101.     String key = testData1[4][0];
  102.     String value = testData1[4][1];
  103.     System.out.println("m.containsKey(\"" + key +
  104.       "\"): " + m.containsKey(key));
  105.     System.out.println("m.get(\"" + key + "\"): "
  106.       + m.get(key));
  107.     System.out.println("m.containsValue(\"" 
  108.       + value + "\"): " + 
  109.       m.containsValue(value)); 
  110.     Map m2 = fill(new TreeMap(), testData2);
  111.     m.putAll(m2);
  112.     printKeys(m);
  113.     m.remove(testData2[0][0]);
  114.     printKeys(m);
  115.     m.clear();
  116.     System.out.println("m.isEmpty(): " 
  117.       + m.isEmpty());
  118.     fill(m, testData1);
  119.     // Operations on the Set change the Map:
  120.     m.keySet().removeAll(m.keySet());
  121.     System.out.println("m.isEmpty(): " 
  122.       + m.isEmpty());
  123.   }
  124.   public static void main(String args[]) {
  125.     System.out.println("Testing HashMap");
  126.     test(new HashMap());
  127.     System.out.println("Testing TreeMap");
  128.     test(new TreeMap());
  129.   }
  130. } ///:~